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© A computer network has a number of computers 
coupled thereto at distinct nodes. A trust realm table 
defines which computers are members of predefined 
trust realms. All the members of each predefined 
trust realm enforce a common set of security pro- 
tocols for protecting the confidentiality of data. Each 
computer that is a member of a trust realm enforces 
a predefined security policy, and also defines a 
security level for each set of data stored in the 
computer. Thus, each message has an associated 
label denoting how to enforce the computer's secu- 
rity policy with respect to the message. A trust realm 
service program prepares a specified message for 
transmission to a specified other computer system. 
To do this it uses the trust realm table to verify that 

100 



both the computer system and the specified com- 
puter system are members of at least one common 
trust realm, and then selects one of those common 
trust realms. The message is transmitted as a pro- 
tocol data unit, which includes a sealed version of 
the message, authenticated identifiers for the send- 
ing system and user, the message's label, and an 
identifier for the selected trust realm. Received pro- 
tocol data units are processed by validating each of 
the components of the received protocol data unit 
before accepting the sealed message in the protocol 
data unit as authentic. Further, the label in the re- 
ceived protocol data unit is used by the receiving 
computer to determine what predefined security poli- 
cy is to be enforced with respect to the message. 
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The present invention relates generally to 
maintaining security within a distributed computer 
system or network, and particularly to methods and 
systems for maintaining security where the phys- 
ical media interconnecting the computers in a dis- 
tributed system are not secure. 

BACKGROUND OF THE INVENTION 

Maintaining security within a distributed com- 
puter system or network has historically been a 
problem. Security in such systems "as several 
aspects, including: (1) authentication of the iden- 
tities of users and systems involved in a commu- 
nication, (2) secure transmission of information, and 
S requiring the system and user which receive 
secure communications to following predefined 
protocols so as to preserve the conf.dent.al.ty of 
the transmitted information. 

In many military computer systems, security is 
ensured by verifying that all the computer hard- 
ware, including communications lines used o .nter- 
connect computers, is physically secure In most 
commercial situations, however, phys.cally secure 
computer hardware and communications l.nes are 
not practical. Therefore security for these commer- 
cial applications must be provided using mecha- 
nisms other than physical security. 

There are a number of publicly ava.lable tech- 
niques for providing reliable authentication of users 
(actually, named members) in a distributed net- 
work, including RSA Public Key authentication and 
Needham & Schroeder's trusted third-party authen- 
tication technique (used in Kerberos, which is a 
trademark of MIT, from MIT's Project Athena). 

However, in many computing environments, 
knowledge of only the user's identity is not suffi- 
cient information in order to determine whether 
access to specific data should be allowed In many 
cases, additional information is needed to make 
that decision. This additional information may take 
many forms, such as where the user's workstation 
is located (e.g.. whether it is in a secure area) o 
what secrecy level the user is operating under at 
the current time. This additional information .s re- 
ferred to as the ''environment" in which the user is 
running. For example, both military and iMMj 
computer systems use the concept of •levels of 
securrty. Basically, a number of distinct secunty 
levels are needed in many systems because some 
information is more confidential than other informa- 
tion, and each set of confidential information has an 
associated set of authorized recipients. 

The users participating in a communication 
cannot be trusted to always correctly represent the 
environment in which they are running. Instead 
secure communications require that the compute 
operating system supporting a user's process must 



be responsible for communicating information 
about the user's environment to other systems in 

the network. 

The present invention helps to provide secure 
5 communications between systems by providing a 
mechanism for ensuring that communicates occur 
within "trust realms" of systems, and also by 
authenticating both the systems and users which 
are participating in a communication. Furthermore, 
,o multiple levels of security are supported by trans- 
mitting validated security level labels along with 
data that is being transmitted, with the labes being 
encoded so that the recipient can verify that the 
specified security level label is authentic. 

SUMMARY OF THE INVENTION 



In summary, the present invention is a com- 
puter security system which strengthens the bas.s 
20 for trust between computers which are exchang.ng 
messages using a network not physically secure 
gainst interlopers. To do this, the present .nven- 
«on provides a trust realm table that defmes wh.ch 
computers are members of predefined trust realms 
25 TL members of each predefined trust ream 
enforce a common set of security protocols for 
protecting the confidentiality of data. 

Each computer that is a member of a trust 
realm enforces a predefined security po icy, i and 
30 also defines a security level for each set of data 
stored in the computer. Thus, each message has 
an associated label denoting how to enforc ithe 
computer's security policy with respect to the mes- 

35 ^ A trust realm service program in each com- 
puter is charged with the task of labelling and 
formatting users' messages for transm.ss.on to 
iecified'other computer systems. The trus realm 
service program is part of the computer's kernel or 
«, operating system and is normally invisible to he 
users of the system - unless they try to breach the 
computer system's security policies by trymg to 
transmit data to another computer tha is not a 
member of a trust realm shared by the users 

45 C °T3ore transmitting a specified message, the 
trust realm service program uses the trust realm 
table to verify that both the local computer system 
and the specified target computer system are 
so members of at least one common trust realm ^ and 
then selects one of those common trust realms. If 
the computer system and the specified computer 
system are not both members of at least one 
common trust realm, the message is not transmrt- 
55 ted because transmission of the message .s no 
authorized - because the specified target computer 
cannot be trusted to enforce the send.ng com- 
puter's security policies. 
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If the two computers are members of a com- 
mon trust realm, the message is transmitted as a 
protocol data unit, which includes a sealed version 
of the message, authenticated identifiers for the 
sending system and user, the message's security 
level label, and an identifier for the selected trust 
realm. 

Received protocol data units are processed by 
validating each of the components of the received 
protocol data unit before accepting the sealed mes- 
sage in the protocol data unit as authentic. Further, 
the security level label in the received protocol 
data unit is used by the receiving computer to 
determine what predefined security policy is to be 
enforced with respect to the message, 

BRIEF DESCRIPTION OF THE DRAWINGS 

Additional objects and features of the invention 
will be more readily apparent from the following 
detailed description and appended claims when 
taken in conjunction with the drawings, in which: 

Figure 1 is a block diagram of a computer 
network coupled to a number of separate computer 
systems. 

Figure 2 depicts one embodiment of a trust 
realm table. 

Figure 3 is a block diagram of two computers, 
interconnected by a network, one of which is trans- 
mitting data to the other. 

Figures 4A and 4B are flow charts of the se- 
cure data transmission method of the present in- 
vention. 

Figure 5 is a block diagram of the data struc- 
ture for messages transmitted from one computer 
to another. 

DESCRIPTION OF THE PREFERRED EMBODI- 
MENT 

Referring to Figure 1 , the present invention is a 
security protocol system, or security protocol tech- 
nique which typically operates in the context of a 
collection 100 of computers 102-108 intercon- 
nected by a local or wide area network 110 or 
some other communications medium. Each of 
these computers 102-108 is said to be located at a 
distinct node of the networked computer system 
100. 

Each computer 102-108 contains the standard 
computer system components, including a data 
processing unit, system bus, random access mem- 
ory RAM, read only memory (ROM), mass storage 
(e.g., magnetic or optical disks), a user interface 
(e.g., keyboard, monitor and printer) and commu- 
nications ports. These physical computer compo- 
nents (not shown) are not modified by the present 
invention and are therefore not described in detail 



herein. 

One item that is used in one preferred embodi- 
ment of the present invention is a secure "naming 
service" 112 that is accessible to all the computers 

5 102-108 via the network. The naming service 112 
is essentially a simple database management sys- 
tem which maintains a set of data that can be 
relied upon as being accurate by all the users of 
the network 112. In the context of the present 

70 invention, the naming service 112 contains listings 
of "trust realms", the meaning of which will be 
explained in more detail below. The naming service 
112 is said to be secure because its contents (and 
delivery thereof) are protected from modification by 

75 unauthorized sources, which allows recipients of 
data from the naming service 112 to know that they 
can rely on the information obtained therefrom. 
There are a number of practical problems involved 
in the construction of secure naming services, and 

20 therefore other embodiments of the present inven- 
tion use an alternate scheme for denoting trust 
realms. 

TRUST REALMS. 

25 

A central concept used by the present inven- 
tion is that of "trust realms." A trust realm is a 
collection of computer systems which share a com- 
mon security policy, and trust one another to main- 

30 tain that policy. Furthermore, the computer sys- 
tems that are members of a trust realm have an 
agreed upon method of communicating an 
"environmental label" or "security level label" as- 
sociated with each message transmitted between 

35 systems. 

Basically, a trust realm is a known set of com- 
puters that can be. trusted to properly handle con- 
fidential information, and to follow a predefined set 
of rules (called a security policy) for handling such 

40 data. 

A single computer can be a member of a 
plurality of distinct trust realms. The reason for 
having more than one trust realm is so that a 
computer system can utilize different security poli- 

45 cies when transmitting data to various different 
computers. More simply, different organizations 
tend to use different security policies for handling 
confidential information, and there is one trust 
realm for each such security policy. For instance, a 

50 military organization may organize data into dif- 
ferent levels of secrecy, including "sensitive", 
"secret", "top secret" and so on. On the other 
hand, a commercial organization might organize 
data into security levels such as: "officers only", 

55 "board of directors only", "managerial info", "all 
employee info", "special project A", and so on. 
Each security policy defines how data that is label- 
led with a particular security level label is to be 
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handled, and thus for each security policy there is 
a predefined set of security level labels. 

Referring to Figure 2, the naming serv.ce 112 
maintains a defined list of trust realms. This ; tot « 
organized as a flat file or database table 130. with 
one row 132 for each computer system that is a 
member of at least one trust realm. The row or 
record for a particular specified computer system 
lists all the trust realms which that system belongs 
to. There are two preferred embodiments of this 

^Inthe embodiment shown in Figure 1. there is 
a secure naming service 112 which contains the 
trust realm table 130. The advantage of this em- 
bodiment is that the security manager in charge of 
maintaining the trust realm table needs to store 
only one copy of the trust realm table 130. which is 
then available for every one to use. The disadvan- 
tage is that it is difficult to design a secure naming 
service. A second embodiment of the trust realm 
table 130 is simply to include a copy of the table in 
every computer system which is a member of at 
least one trust realm. This has the obvious dis- 
advantage of requiring that updates to the table be 
copied into all these computer systems in a way 
that is safe and secure. However, this second em- 
bodiment has the advantage of being relatively 
easy to implement. 

GLOSSARY. 



The following are definitions of terms used 

ASSOCIATION. An association is formed between 
two computers when the present invent.on has 
successfully exchanged authentication, trust realm, 
and environmental information describing the call- 
ing and target users. This exchange allows the two 
systems to form a common security context de- 
scribing the environment shared between two us- 
ers The association allows a sending system to 
refer to this previously established security context 
when sending any additional messages between 
the users, rather than reauthenticating the sending 
user and his environment all over again. 
AUTHENTICATED MESSAGE. Authenticated data 
is data which has been either encrypted or signed 
using authentication techniques which allow the 
origin (i.e., the sender) of the data to be validated. 
"Signing" a message (i.e.. a set of data) is s,m ar 
to physically signing a letter or a check, in that the 
signature validates the authenticity of the signed 
document (or set of data). The signing of digrtal 
messages in computer systems is performed using 
authentication techniques, a number of which are 
used in prior art computer systems for validatng 
various types of data transmissions. In the context 
of the present invention, messages and the asso- 



ciated information sent along with messages 
(including sending system and user identifiers, trust 
realm identifier, and label) are all authenticated so 
as to allow the receiving system to verify that the 
5 received data was in fact sent by the alleged 
sending system. The source of a message or other 
set of data can be authenticated by either signing 
with a digital signature, or by encrypting the mes- 
sage using a key shared only with a previously 
ra-,, established source. Details of data authentication 
signing, encryption and decoding are not discussed 
herein because these topics are well known to 
those skilled in the art. These prior art techniques 
are used as tools by the present invention to imp le- 
, 5 ment portions of the present invention's trust realm 
security methodology. . 
ENVIRONMENT and LABEL. In most commercially 
available computer systems that have internal se- 
curity protection, all data stored in the computer is 
20 tagged or labeled with so-called "environment in- 
formation, which is indicative of the security char- 
acteristics of the process in the computer that 
created that data. In this document, the terms 
"security level" and "environment" are used inter- 
25 changeably to refer to those characteristics of a 
user which are pertinent to the security policy or 
policies used by the computer. 
TARGET A target system or a target application is 
the system or application to which communication 
30 is directed by a calling system or user. 

SECURITY POLICY. A security policy is a set of 
rules which determine the availability of data to 
individual computers and/or users, along with ac- 
companying rules specifying actions that .must be 
35 taken upon providing or denying access data by a 
specified computer or user. In many cases, these 
rules are dependent on factors other than the iden- 
tities of the computers and users to whom the data 
is being sent. In particular, the environment or 
40 security level labels associated with transmitted 
data often determine how the transmitted data .s to 
be handled. 



MESSAGE HANDLING. 



45 



Referring to Figure 3. the basic situation in 
which the invention operates is as follows A user 
running on a first computer 150. herein called the 
calling system, wants to send a message to a 
so specified user running on a specified second com- 
puter 170. herein called the target or receiving 
system. Figure 3 shows the various software mod- 
ules that are involved in the transmission of this 
message. These software modules include security 
55 mechanisms which determine whether transmission 
of the message is allowed, how the message is to 
be encoded, and what security protocols are to be 
used during transmission of the message as well 
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as after receipt of the message. 

Referring to the block diagram in Figure 3 and 
the flow chart in Figure 4A, the transmission pro- 
cess begins when an initiating application 152 in 
the calling system 150 generates a message 153 5 
and sends it to the calling system's network inter- 
face 154 with instructions that the message is to be 
sent to a specified user (or application program) 
running on a specified computer (step 200 in Fig- 
ure 4A). The network interface 154 is the boundary w 
between the potentially untrusted user program and 
the trusted networking programs with the computer 
system. 

If the calling computer system 150 had no 
security mechanisms for controlling the flow of 75 
messages into and out of the computer 150, the 
network interface 154 would directly send the mes- 
sage 153 to the computer's transport service rou- 
tine 155, which handles the actual transmission of 
data over a network. The transport service routine 20 
155 handles the protocols associated with data 
transmission over a particular type of network, such 
as Internet's TCP or UDP, ISO's Connection Ori- 
ented or Connectionless Transport Services, or 
whatever underlying networking protocol stack is 25 
being used. Each such network has a predefined 
sequence of actions which must be performed in 
order to successfully transmit a message to a 
specified destination, and the details of that pro- 
tocol are handled by the transport service routine 30 
155. 

In some embodiments of the present invention, 
there is a special provision for "unclassified data", 
which is data that the computer's internal security 
system denotes as being unrestricted by security 35 
protocols. If the calling computer system 150 has 
such a provision, and the message being sent is 
unclassified (step 202), then the message is trans- 
mitted without further processing (step 204). In 
other embodiments of the invention, no provision is 40 
made for special handling of "unclassified data" 
because all the computer systems on the relevant 
computer network require that all transmitted data 
be treated as being confidential, or at least as 
having an associated data security level. 45 

Assuming that the message is either classified 
for security purposes or that the calling system 
does not have unclassified data, the message 153, 
now in the trusted, or protected, part of the com- 
puter system is next processed by a trust realm so 
service program (TRSP) 156. The TRSP's first job 
is to determine whether the calling system and the 
target system are both members of a shared trust 
realm (steps 206 and 208). This is done by retriev- 
ing from the trust realm table 130 (1) the set of 55 
trust realms associated with the target system and 
(2) the set of trust realms associated with the 
calling system. Note that if the target system is not 



listed in the trust realm table 130, this means that it 
is not a member of any trust realms. If the two 
systems are not both members of a common trust 
realm (or, alternately stated, if the target system is 
not a member of any of trust realms of which the 
calling system is a member) then the message 
transmission sequence is aborted and the message 
is not sent (step 210). Basically, if there isn't a 
common trust realm for the two systems, transmis- 
sion of the message is unauthorized and therefore^ 
the message is not sent. 

Next, the TRSP 156 must select a trust realm 
from among the set of trust realms of which both 
the calling and target systems are members (step 
212). If there is only one common trust realm, then 
that is selected; otherwise one of the trust realms 
must be selected. The method of making this se- 
lection will depend on security considerations that 
are not relevant to the present invention, but gen- 
erally the trust realms will either be prioritized in 
terms of which should be selected when more than 
one common trust realm exists, or the selection of 
a trust realm will depend on the characteristics of 
the message which is being sent. Once a trust 
realm is selected, the TRSP 156 calls the selected 
trust realm's security management program 158. 

A trust realm security management program 
158 is the program responsible for enforcing the 
security policies of a particular trust realm. It han- 
dles data security level labels in accordance with a 
predefined set of rules for the trust realm and 
interacts with the trusted computing base 160 to 
obtain the local data security level labels asso- 
ciated with messages that are being sent. It also 
interacts with the trusted computing base 160 so 
that the data security level labels on received mes- 
sages can be converted back into the format asso- 
ciated with the computer's local data security level 
labels. 

A trusted computing base 160 is that part of a 
computer system which is responsible for maintain- 
ing the computer's local security policy. This 
means that it maintains the confidentiality of data 
stored in the system and prevents unauthorized 
data sharing between users and processes running 
on the computer. The trusted computing base 160 
is therefore responsible for assigning security level 
labels or environmental information to processes 
running on the computer and to the data that is 
created or stored by those processes. 

Next, the trust realm security management pro- 
gram 158 calls upon the trusted computing base 
(TCB) 160 to determine the environment or data 
security level label associated with the initiating 
application 152 (i.e., associated with the message 
that is being transmitted). Note that since a number 
of different types of computers may share a trust 
realm, the internal formats used to denote local 
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data security level labels may vary from computer 
to computer within a trust realm. Therefore, rf nec- 
essary the trust realm security management pro- 
aram 158 converts the local data security level 
label used by the calling computer 150 into another 
format that is used by the trust * 
ting data security level labels (step 214). IT the TOT 
160 approves of sending message 153 (step 
then the permission and new format label are re- 
turned to the TRSP 155. Otherwise. perm.8S.on is 
denied, the message transmission sequence ,, s ab- 
orted and the message is not sent (step ,210* .The 
trust realm security management program 158 may 
also perform any checks required by he ttust 
realm which are not normally done by the local 

^fuming permission to send the message 
was obtained from the TCB 160. the message to 
be sent is now converted into a new format so as 
! irSde authenticated identifiers for the caU,g 
system and user, the trust realm, and also to 
nclude a security level labe. (step 218). The ne* 
step after that is to authenticate the message so 
that the receiving system 170 can validate he 
Sewed message (step 220). More «*^>* 
calling system and user are authenticated, the trust 
Sa m identifier and security level label are s.gned 
under the system authentication, and 
saae is signed under the user authentication. Au- 
henti ation and signing are performed by having 
Jo trust realm service program 156 call an autter, 
ication service program 162 which s.gns specified 
lets of data so as to validate the source of the 
s^ned data. In some embodiments the signed data 
wSl be encrypted so that interlopers mon.tor.ng 
Network traffic will not be able to determine the 
content of the messages being tran s™*^ 

The resulting data structure for the transmitted 
message 153B. shown in Figure 5. is then sent o 
Z calling computer's transport service module 
15 5 for transmission over a communications net- 
work 110 to the target computer system 170 (step 
222) The data structure shown in Figure 5. gen- 
eral y known as a protocol data unit ! 250 contems 
protocol control information 251. wh.ch '"eludes the 
Lt realm being used 252. the data secuntv r level 
abe . denoted in the format associated with the 
trust realm 254. and any other information 256 
needed to specify the protocols to be used when 
handling the data at the received computer system 
? a 7o which are signed values). This information is 
-sealed", which means that it is either encrypted or 
sianed using the authentication service program 
162 Authentication information for the calling sys- 
tem 262 and user 266 may also be present. Once 
an association has been established between . two 
computer systems, this information can be abbre- 
viated by sending a reference to the existing asso- 



ciation 257, if necessary, and those aspects of the 
security level label which have changed 258 since 
the association was established. The message date 
structure also includes a service data unit 260 
5 which contains the user's "sealed message (i*.. a 
message which has either been encrypted or 

""Referring to Figure 4B, when the transmitted 
message is received (step 230) at the receiving 
, 0 system 170, the received message 153B is ^ pro- 
cessed as follows. Unclassified messages that are 
transmitted outside the trust realm security pro- 
tocols are recognized as such (step 232). and are 
routed by the trust realm service program 174 
J6 directly to the receiving application 186 via network 
interface 184 (step 234), without performing the 
validation steps described below. 

Assuming that the received message 1MB » 
not unclassified, the received message is first sent 
w by the receiving computer's transport serv.ee rou- 
Se 172 to that computer's trust realm service 
program 174 for validation. The trust realm service 
program 174 validates the received message by 
Stag the receiving system's authentication ser- 
25 vice program 178 (step 236). 

If any part of the message (i.e.. the transmitted 
protocol data unit) is not validated by the auflien- 
Scation service 178 (step 238), the messag : deliv- 
ery process is aborted and the received message 
30 is dLarded (step 240). Failure to validate the 
mes age means that either the alleged sender -Ad 
not send this message (i.e., it is a message J om 
an interloper posing as the sending 
some portion of the message was changed by an 
35 interloper during the transmission process. 

If the sending and receiving system identifiers 
are successfully validated, this means that the al- 
,eged sending system did in fact send the mes 
sage, and that the sending system intended the 
«, receiving system to be the target system. Furthe - 
rmore, the security level labe. for the message is 
validated and therefore known to be valid. 

The receiving system's TRSP 174 then che k 
the trust realm table 182 to determine whether the 
« entified sending system is a member o the , m* 
realm specified by the received message 153B and 
whether the receiving system is also in that trust 
Tel (steps 242 and 244). If not. then the mes- 
sage was improperly transmitted, and the message 
so S discarded as being unauthorized for rece.pt by 
this system 170 (step 240). 

Assuming that the trust realm check is suc- 
cessful (step 244). the received security level label 
? hen passed to the appropriate trust realm secu- 
55 rity manager 176 to be converted, if necessa^ 
into the format used by the receivmg computer s 
trusted computing base 180 (step 245)^ 

The trust realm security manager 176 then 
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checks with the TCB 180 to get permission to 
deliver the labelled message to the target applica- 
tion (step 246). If permission is not granted (step 

247) , then the message is not delivered (step 240). 
Otherwise control of the validated message, includ- s 
ing its security level label, is transferred back to 

the trust realm service program 174. 

Finally, if the message has passed all these 
tests, the message portion of the converted mes- 
sage 153C (Which is identical to the originally sent to 
message 153) is transmitted via the network inter- 
face 184 to the receiving application 186 (step 

248) . 

ESTABLISHING AN ASSOCIATION. is 

When all the trust realm and security level 
label information has been validated (steps 236, 
238, 242 and 244), this information is stored in the 
receiving system, thereby establishing an associ- 20 
ation with the sending system. The establishment 
" of an association enables more efficient data trans- 
mission by allowing the sending system to elimi- 
nate those portions of the protocol control informa- 
tion 251 (see Figure 5) which have not changed 25 
since the last message sent between the two sys- 
tems. Furthermore, failure to establish an associ- 
ation automatically results in rejection of the re- 
ceived message because the received message 
has not been proven to be authentic. In the pre- 30 
ferred embodiment, associations are automatically 
terminated after a predefined period of time if not 
renewed by the continued transmission of data 
between the two systems. 

35 

ALTERNATE EMBODIMENTS. 

While the present invention has been de- 
scribed with reference to a few specific embodi- 
ments, the description is illustrative of the invention aq 
and is not to be construed as limiting the invention. 
Various modifications may occur to those skilled in 
the art without departing from the true spirit and 
scope of the invention as defined by the appended 
claims. 45 

Claims 

1. In a computer network having a multiplicity of 

computers coupled thereto, message transmis- 50 
sion apparatus comprising: 

trust realm defining means for storing in- 
formation denoting which ones of said comput- 
ers are members of predefined trust realms; 
wherein all the members of each predefined 55 
trust realm enforce a common set of security 
protocols for protecting confidentiality of data; 
and 



security apparatus in each of a plurality of 
said computers, comprising: 

a trusted computing base which enforces a 
predefined security policy in said computer 
and which defines a security level for each set 
of data stored therein; 

authentication means for authenticating 
and validating messages sent to another com- 
puter via said network; 

each said message comprising data hav- 
ing an associated label denoting how said 
trusted computing base is to enforce security 
policy with respect to said message; 

trust realm service means, coupled to said 
trusted computing base, authentication means 
and trust realm defining means, for preparing a 
specified message for transmission to a speci- 
fied other computer system, including means 
for 

obtaining trust realm information stored by 
said trust realm defining means, verifying that 
both said computer system and said specified 
computer system are members of at least one 
common trust realm, and selecting a trust 
realm from among said at least one common 
trust realm, 

authenticating an identifier for said com- 
puter, and sealing said message, said label 
associated with said message, and an identifier 
for said selected trust realm, and 

transmitting to said specified other com- 
puter a protocol data unit including said 
authenticated identifier for said computer, said 
sealed message, said label associated with 
said message, and said identifier for said se- 
lected trust realm; 

said trust realm service means further in- 
cluding means for receiving protocol data units 
transmitted by other ones of said computers 
via said network, and means for validating 
messages received by said computer, includ- 
ing means for validating each of said compo- 
nents of a received protocol data unit before 
accepting said sealed message in said pro- 
tocol data unit as authentic. 

2. The message transmission apparatus set forth 
in Claim 1, said trust realm service means 
including means for aborting transmission of a 
message when, according to said information 
stored in said trust realm defining means, said 
computer and said specified other computer 
are not members of a common trust realm. 

3. The message transmission apparatus set forth 
in Claim 1, said trust realm service means 
including means for conveying said label in 
said received protocol data unit to said trusted 
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computing base so that said trusted computing 
base P wil» entorce a predefined ^J*" 
with respect to said message m sad received 
protocol data unit in accordance with sa.d la- 
bel. 

4. in a computer network having a multiplicity oi 
computers coupled thereto, a method of en 
oSg security protocols when jng 
messages between computers v.* Sa.d net 
work, the steps of the method ~nipns.ng: 

storing information denoting computers 
which are members of predefined trust realms 
Irein all the members of each prede med 
trust realm enforce a common se of secunty 
protocols for protecting confident.al.ty of date 

authenticating and validating a specfied 
message that an application runn.ng .n a com- 
puter is attempting to send to a spec** ofiw 
computer via said network, each sa. I message 
comprising data having an assocated label 
denoting how a predefined security pohcy .s to 
be enforced with respect to said message, 
said authenticating and val.dat.ng steps in 

eluding the steps of: . 

accessing said stored trust realm .nforma- 
tion verifying that both said computer system 
and' said specified computer system are mem- 
bers of at least one common trust realm and 
Meeting a trust realm from among sa.d at 
least one common trust realm; 

sSng said message, authenticating sa.d 
,abel associated with said message authen- 
Sng an identifier for said , selected wj 
realm, and authenticating an .dent.f.er for sa.d 

C °T— ng to said specified other co- 
puter a protocol data unit inc.ud.ng said sealed 
message, said authenticated label. sa.a 
Seated identifier for said computer, and 
said authenticated identifier for said selected 

^S'ng said protocol data unit at said 
specified other computer; and 

validating each component of sa.d re 

sealed message in said protocol data un.t as 
authentic. 

5 The method of enforcing security protocols 
5 - ^Transmitting messages between compu, 
ers as set forth in Claim 4, .nclud.ng the step 
o aborting transmission of a message when, 
lite said stored trust realm , nforma- 
<ion said computer and said specfied other 
computer are not members of a common trust 

realm. 



The method of enforcing security protocols 
when transmitting messages between comput- 
ers set forth in Claim 4, including the step of 
enforcing a predefined security .pohcy wrfh re- 
soect to said message in sa.d received pro- 
Sdata unit in accordance with said label .n 
said received protocol data unit. 
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